#include <bits/stdc++.h>
using namespace std;
struct node {
  int l, r;
} a[100005];

int main() {
  int n;
  cin >> n;
  for (int i = 1; i <= n; i++) {
    cin >> a[i].l >> a[i].r;
  }
  sort(a + 1, a + n + 1,
       [](node a, node b) { return a.l < b.l || (a.l == b.l && a.r < b.r); });
  a[n + 1].l = 1e9;
  a[n + 1].r = 1e9;

  int ans = 0;

  int left = a[1].l;
  int right = a[1].r;

  for (int i = 2; i <= n + 1; i++) {
    if (a[i].l <= right) {
      right = max(right, a[i].r);
    } else {
      cout << left << " " << right << endl;
      left = a[i].l;
      right = a[i].r;
    }
  }

  return 0;
}